//const baseUrl = 'http://192.168.31.33/';
const baseUrl = 'https://hr.gukecloud.com/';
//const baseUrl = '';
// 这里的Vue为Vue对象(非创建出来的实例)，vm为main.js中“Vue.use(httpInterceptor, app)”这一句的第二个参数，
// 为一个Vue的实例，也即每个页面的"this"
// 如果需要了解这个install方法是什么，请移步：https://uviewui.com/components/vueUse.html

const install = (Vue, vm) => {
	// 此为自定义配置参数，具体参数见上方说明
	Vue.prototype.$u.http.setConfig({
		baseUrl: baseUrl,
		// 设置为json，返回后会对数据进行一次JSON.parse()
		//	dataType: 'json',
		//showLoading: false, // 是否显示请求中的loading
		loadingText: '努力加载中~',
		loadingTime: 800, //请求超过8秒显示loding
		//loadingMask: true, // 展示loading的时候，是否给一个透明的蒙层，防止触摸穿透
		originalData: true, // 是否在拦截器中返回服务端的原始数据
		// 设置自定义头部content-type
		// header: {
		// 	'content-type': 'xxx'
		// }
	});
	
	   // 请求拦截，配置Token等参数
		Vue.prototype.$u.http.interceptor.request = (config) => {
			// 引用token
			// 方式一，存放在vuex的token，假设使用了uView封装的vuex方式
			// 见：https://uviewui.com/components/globalVariable.html
			// config.header.token = vm.token;
			
			// 方式二，如果没有使用uView封装的vuex方法，那么需要使用$store.state获取
			// config.header.token = vm.$store.state.token;
			
			// 方式三，如果token放在了globalData，通过getApp().globalData获取
			// config.header.token = getApp().globalData.username;
			
			// 方式四，如果token放在了Storage本地存储中，拦截是每次请求都执行的
			// 所以哪怕您重新登录修改了Storage，下一次的请求将会是最新值
			// const token = uni.getStorageSync('token');
			// config.header.token = token;
			config.header.Token = uni.getStorageSync('token');
			
			// 可以对某个url进行特别处理，此url参数为this.$u.get(url)中的url值
			if(config.url == 'api/login/login') config.header.noToken = true;
			// 最后需要将config进行return
			return config;
			// 如果return一个false值，则会取消本次请求
			// if(config.url == '/user/rest') return false; // 取消某次请求
		}
		
		
		// 响应拦截，判断状态码是否通过
		Vue.prototype.$u.http.interceptor.response = (res) => {
			
			//服务器没有返回数据  失败
			if(!res.data){
				
			   return false;
			}
			//返回正常
			res = res.data;
			
			if(res.code == 401) {
				// 假设201为token失效，这里跳转登录
				vm.$u.toast('请重新登录');
				setTimeout(() => {
					// 此为uView的方法，详见路由相关文档
					vm.$u.route('/pages/login/login')
				}, 1500)
					
				return false;
			}else if(res.code == 1){
				//返回正常
				// res为服务端返回值，可能有code，result等字段
				// 这里对res.result进行返回，将会在this.$u.post(url).then(res => {})的then回调中的res的到
				// 如果配置了originalData为true，请留意这里的返回值
				return res.data;		
			}else if(res.code == 0){ 
				vm.$u.toast(res.msg);
				return false;
			}else{
				// 如果返回false，则会调用Promise的reject回调，
				// 并将进入this.$u.post(url).then().catch(res=>{})的catch回调中，res为服务端的返回值
				return false;
			}
		}
}
export default {
	install
}